/*
    @author TTDB
    @create 2025/9/9
*/
public class BubbleSort {
    //冒泡排序
    //[64, 34, 25, 12, 22, 11, 90]
    public static void main(String[] args) {
        int[] arr = {64, 34, 25, 12, 22, 11, 90};
        bubbleSort(arr);
        System.out.println("冒泡排序结果: " + java.util.Arrays.toString(arr));
    }

    private static void bubbleSort(int[] arr) {
        for(int i = 0; i < arr.length - 1; i++){
            boolean swapped = false; // 优化：如果本轮没有交换，说明已经有序
            for(int j = 0; j < arr.length - 1 - i; j++){
                if(arr[j] > arr[j + 1]){
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
            // 如果没有发生交换，说明数组已经有序，提前结束
            if(!swapped){
                break;
            }
        }
    }
}
